<?php

/**
 * EXHIBIT A. Common Public Attribution License Version 1.0
 * The contents of this file are subject to the Common Public Attribution License Version 1.0 (the “License”);
 * you may not use this file except in compliance with the License. You may obtain a copy of the License at
 * http://www.oxwall.org/license. The License is based on the Mozilla Public License Version 1.1
 * but Sections 14 and 15 have been added to cover use of software over a computer network and provide for
 * limited attribution for the Original Developer. In addition, Exhibit A has been modified to be consistent
 * with Exhibit B. Software distributed under the License is distributed on an “AS IS” basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language
 * governing rights and limitations under the License. The Original Code is Oxwall software.
 * The Initial Developer of the Original Code is Oxwall Foundation (http://www.oxwall.org/foundation).
 * All portions of the code written by Oxwall Foundation are Copyright (c) 2011. All Rights Reserved.

 * EXHIBIT B. Attribution Information
 * Attribution Copyright Notice: Copyright 2011 Oxwall Foundation. All rights reserved.
 * Attribution Phrase (not exceeding 10 words): Powered by Oxwall community software
 * Attribution URL: http://www.oxwall.org/
 * Graphic Image as provided in the Covered Code.
 * Display of Attribution Information is required in Larger Works which are defined in the CPAL as a work
 * which combines Covered Code or portions thereof with code not governed by the terms of the CPAL.
 */

/**
 * @author Egor Bulgakov <egor.bulgakov@gmail.com>
 * @package ow_utilities
 * @since 1.0
 */

require_once(OW_DIR_LIB . 'wideimage' . DS . 'WideImage.php');

class UTIL_Image
{
	/**
	 * We'll store image here
	 *
	 * @var WideImage_Image
	 */
    private $image;
    
    /**
     * Path to source image file
     *
     * @var string
     */
    private $sourcePath;
    
    /**
     * @var boolean
     */
    private $imageResized = false;

    /**
     * Class constructor
     *
     * @param string $sourcePath
     */
    public function __construct( $sourcePath, $format = 'JPEG' )
    {
    	$this->sourcePath = $sourcePath;
    	
    	$this->image = WideImage::load($sourcePath, $format);
    }
    
    /**
     * Copies image
     *
     * @param string $destPath
     * 
     * @return UTIL_Image
     */
    public function copyImage( $destPath )
    {
        $this->image->saveToFile($destPath);

        return $this;
    }
    
    /**
     * Resizes image
     *
     * @param int $width
     * @param int $height
     * @param string $destPath
     * @param boolean $crop
     * 
     * @return UTIL_Image
     */
    public function resizeImage( $width, $height, $crop = false )
    {
        $iWidth = $this->image->getWidth();
        $iHeight = $this->image->getHeight();
        
        $this->imageResized = ($width <= $iWidth) || (isset($height) && $height <= $iHeight) ? true : false;
        
        if ( $width == null )
        {
            $width = $iWidth;
        }
        else 
        {
            $width = $width > $iWidth ? $iWidth : $width;
        }
        
        if ( $height == null )
        {
            $height = $iHeight;
        }
        else
        {
            $height = $height > $iHeight ? $iHeight : $height;
        }         
    	
        if ( $crop )
        {
        	$wHalf = ceil($width / 2);
        	$hHalf = ceil($height / 2);

            $this->image = $this->image
        	   ->resize($width, $height, 'outside')
        	   ->crop('50%-' . $wHalf, '50%-' . $hHalf, $width, $height);
        }
        else 
        {
        	$this->image = $this->image->resize($width, $height);
        }

        return $this;
    }
    
    /**
     * Crops image
     *
     * @param int $left
     * @param int $top
     * @param int $width
     * @param int $height
     * 
     * @return UTIL_Image
     */
    public function cropImage( $left, $top, $width, $height )
    {
        $this->image = $this->image->crop($left, $top, $width, $height);

        return $this;
    }
    
    /**
     * Apply watermark to image
     *
     * @param string $wmPath
     * @param int $opacity
     * @param int $horPos
     * @param int $vertPos
     * @param int $margin
     * 
     * @return UTIL_Image
     */
    public function applyWatermark( $wmPath, $opacity = 100, $horPos = 'right', $vertPos = 'bottom', $margin = 5 )
    {
        $wmImage = WideImage::load($wmPath);
        
        $wmWidth = $wmImage->getWidth();
        $wmHeight = $wmImage->getHeight();

        switch ( $horPos )
        {
        	case 'right':
        		$horCoord = '100%-' . ($wmWidth + $margin);
        		break; 
        		
        	case 'left':
                $horCoord = '0%+' . $margin;
        		break;

        	default:
        		$horCoord = '100%-' . ($wmWidth + $margin);
        }
        
        switch ( $vertPos )
        {
            case 'bottom':
                $vertCoord = '100%-' . ($wmHeight + $margin);
                break;
                        
            case 'top':
                $vertCoord = '0%+' . $margin;
                break;
                
            default:
            	$vertCoord = '100%-' . $wmHeight + $margin;
        }
        
        $this->image = $this->image->merge($wmImage, $horCoord, $vertCoord, $opacity);
        
        return $this;
    }
    
    /**
     * Copies image
     *
     * @param string $destPath
     * 
     * @return UTIL_Image
     */
    public function saveImage( $destPath = null )
    {
    	if ( !isset($destPath) )
    	{
    	   $this->image->saveToFile($this->sourcePath);
    	}
    	else 
    	{  
            $this->image->saveToFile($destPath);
    	}
    	
    	return $this;
    }

    /**
     * Returns image width
     *
     * @return int
     */
    public function getWidth()
    {
        return $this->image->getWidth();
    }

    /**
     * Returns image height
     *
     * @return int
     */
    public function getHeight()
    {
        return $this->image->getHeight();
    }
    
    public function imageResized( )
    {
        return $this->imageResized;
    }
    
    /**
     * Release memory allocated for image
     */
    public function __destruct()
    {
    	$this->image->destroy();    	
    }
}